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(54) Force page zero paging scheme for microcontrollers 

(57) A microcontroller architecture that adds a dedi- 
cated bit in the op-code decode field to force data 
access to take place on page 0 of the random access 
memory (RAM) for that instruction. This allows the user 
to have any page selected and still have direct access to 
the special function registers or the register variables 
which are located on page 0 of the RAM. The setting of 
the dedicated bit will not affect the current operation of 
the microcontroller nor will the setting of the bit modify 
the currently selected address stored in the op-code 
instruction cunerrtly being executed by the microcontrol- 
ler. 
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Description 

BACKGROUND OF THE INVENTION 

Field of the Invention: 5 

This invention relates generally to microcontrollers 
and, more specifically, to a random access memory 
paging scheme for a microcontroller which will allow a 
user to have any page selected in the random access w 
memory of the microcontroller and still have direct 
access to special function registers or the register vari- 
ables without modifying the page select register or a 
current instruction. 

15 

Description of the Prior Art 

Current microcontrollers, inclucfing PIC microcon- 
trollers, use a random access memory (RAM) paging 
scheme to address ail the data memory. This scheme is so 
extremely cumbersome in that it takes several instruc- 
tions to make sure the user is writing or reading the 
proper address in the RAM. It also complicates the job 
of the C-compiler since the C-compiler must keep track 
of which page is currently selected in the RAM. This 25 
presents even more problems when handling interrupts. 

In classic microcontroller architecture, the above 
problem would be solved by increasing the op-code field 
to handle larger addresses. However, increasing the op- 
code field has the disadvantage of increasing the size or 30 
the microcontroller and thus increasing the overall cost 
of the microcontroller. Another way to alleviate the RAM 
paging problem is to map all special function and regis- 
ter dedicated memory space that is available in every 
bank or page. This waste precious RAM space since 35 
every location that is mapped takes up one general pur- 
pose RAM location in every bank. If the micro has eight 
(8) pages, seven (7) locations of RAM are wasted. 

Therefore, a need existed to provide an improved 
microcontroller architecture and paging scheme. The 40 
improved microcontroller architecture and paging 
scheme must allow for direct access to special function 
registers. The improved microcontroller architecture 
and paging scheme must allow direct access to special 
function registers without modifying the page select reg- 45 
ister of the current instruction being executed by the 
microcontroller. The improved microcontroller architec- 
ture and paging scheme must further allow for direct 
access to special function registers without increasing 
the size of the microcontroller. 50 

SUMMARY OF THE INVENTION 

In accordance with one embodiment of the present 
invention, it is an object of the present invention to pro- 55 
vide an improved microcontroller architecture and pag- 
ing scheme. 

It is another object of the present invention to pro- 



vide an improved microcontroller architecture and pag- 
ing scheme that allows direct access to special function 
registers without modifying the page select register of 
the current instruction being executed by the microcon- 
troller. 

It is still another object of the present invention to 
provide an improved microcontroller architecture and 
paging scheme that allows direct access to special 
function registers without increasing the size of the 
microcontroller. 

BRIEF DESCRIPTION OF TEE PREFERRED 
EMBODIMENTS 

In accordance with one embodiment of the present 
invention, a paging scheme for a microcontroller that 
uses data random access memory to allow tracking of a 
currently selected address in the random access mem- 
ory. The method comprises the step of dedicating a bit 
in each op-code instruction of the microcontroller. When 
the bit is set, the bit forces data access, to take place on 
a section of the random access memory storing special 
and general purpose registers while not affecting cur- 
rent operations of the microcontroller. Even when set, 
the dedicated bit will not modify the currently selected 
address stored in the op-code instruction currently 
being executed by the microcontroller. The method may 
further comprise the steps of: linearizing an entire 
address range of the random access memory and ded- 
icating a first address section of the random access 
memory to the special and general purpose registers. 

In accordance with another embodiment of the 
present invention, a microcontroller having force page 
zero architecture is disclosed. The microcontroller has a 
random access memory that has an entire linearized 
address range. The random access memory is divided 
into a plurality of pages wherein the first page is dedi- 
cated to special and general purpose registers. A dedi- 
cated bit in each op-code instruction of the 
microcontroller is used to force data access to take 
place on the first page of the random access memory 
which stores the special and general purpose registers. 
The setting of the dedicated bit will not affect the current 
operations of the microcontroller nor will the setting of 
the bit modify the currently selected address stored in 
the op-code instruction currently being executed by the 
microcontroller. 

The foregoing and other objects, features, and 
advantages of the invention will be apparent from the 
following, more particular, description of the preferred 
embodiments of the invention, as illustrated in the 
accompanying drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a simplified block diagram of a prior art 
paging scheme for a microcontroller to address 
data memory. 
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Figure 2 is a simplified block diagram of a microcon- 
troller having a force page zero paging scheme. 
Figure 3 is a simplified block diagram of an op-code 
instruction. 

5 

DETAILED DESCRIPTION OF THE PREFERRED 
EMBODIMENTS 

Referring to Figure 1, a simplified block diagram of 
a prior art paging scheme 10 for a microcontroller to 10 
address data memory is shown. As stated above, all 
special function and register variables 12 are mapped in 
the first page of the RAM. However, since the special 
function registers 12 have to be accessible all the time, 
the special function registers 12 are mapped into every 75 
bank (i.e., Bank 1-7). This waste precious RAM space 
since every location that is mapped takes up one gen- 
eral purpose RAM location. 

Referring to Figure 2, a microcontroller 20 with 
force page 0 architecture is shown. The microcontroller 20 
20 uses a random access memory (RAM) 22 for storing 
data. The size of the RAM 22 is based on the particular 
use of the microcontroller 20. As can be seen from Fig- 
ure 2, the entire address range of the RAM 22 is linear- 
ized. By linearizing the address range, the problems 25 
associated with banking and page bits of the prior art 
are removed. 

However, in general, many of the op code instruc- 
tions of the microcontroller 20 are limited in address 
space. In the preferred embodiment of the present 30 
invention, the microcontroller 20 is an 8-bit PIC micro- 
controller. Thus, many of the op-code instructions of the 
microcontroller 20 are limited to an 8-bit address. For 
this reason, the linear address range is broken into a 
plurality of pages. If the microcontroller 20 is an 8-bit 35 
microcontroller, the RAM 22 is divided into a plurality of 
256K byte pages. 

The first page 24 (i.e., page 0) is used for storing 
the special function registers 12 (Figure 1) and general 
purposes registers 14 (Figure 1). As stated above, 40 
these registers 12 and 14 need to be accessible at all 
times. This is required because if an interrupt is called 
and the user wants to use an interrupt service routine, 
the user has to deal with the special function and gen- 
eral purpose registers 12 and 14 which are stored on 45 
the first page 24. In the preferred embodiment of the 
present invention, the first page 24 is broken into two 
128K byte sections. The first 128K section stores the 
special function registers while the second 128K section 
stores the general purpose registers. so 

Referring now to Figures 2 and 3, in order to have 
the special and general purpose registers 12 and 14 
accessible at all times, a bit 36 is dedicated in each op- 
code instruction 30 of the microcontroller 20 which 
when set forces data access to take place on the first 55 
page 24 (i.e., page 0) of the RAM 22. The setting of the 
dedicated bit does not affect the current operation of the 
microcontroller 20 nor does it modify the currently 
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selected address stored in an op-code instruction cur- 
rently being executed by the microcontroller 20. Thus, 
no matter where the user is in the RAM 22, if the bit 36 
is set, the current instruction will always affect the first 
page (i.e., page 0) which stores the special and general 
purpose registers 12 and 14. Thus, if a user is in the 
general purpose RAM area (i.e., any page except the 
first page, page 0) and receives an interrupt, the inter- 
rupt service routine can set the dedicated bit 36 in the 
op-code instruction 30. The user may then deal with the 
special and general purpose registers 12 and 14 with- 
out affecting anything else the microcontroller 20 was 
doing. When the interrupt has been properly serviced, 
the microcontroller 20 may go back to the current 
address location in the RAM 22 since the address loca- 
tion was not modified during the service of the interrupt. 

In the preferred embodiment of the present inven- 
tion for an 8-bit microcontroller 20, the op-code instruc- 
tion 30 is a 16-bit instruction. The first 8-bits section 32 
define the instruction and tells the microcontroller 20 
what to do. The second 8-bits section 34 defines the 
address where the instruction is to be executed. The 
dedicated bit 36 is added to the first 8-bit section 32 of 
the op-code instruction 30 in order not to alter the 
address stored in an op-code instruction 30 when the 
dedicated bit 36 is set. 

In the preferred embodiment of the present inven- 
tion, the dedicated bit 36 is only added to numeric 
processing op-code instructions of the microcontroller 
20. By removing a few non-numeric processing op code 
instructions from the instruction decode map of the 
microcontroller 20, the dedicated bit 36 may be added in 
the numeric processing op-code instructions of the 
microcontroller 20 without increasing the size of the 
instruction decode map of the microcontroller 20. 

While the invention has been particularly shown 
and described with reference to preferred embodiments 
thereof, it will be understood by those skilled in the art 
that the foregoing and other changes in form, and 
details may be made therein without departing from the 
spirit and scope of the invention. 

Claims 

1. A paging scheme for a microcontroller that uses 
data random access memory to allow tracking of a 
currently selected address in said random access 
memory comprising the step of dedicating a bit in 
each op-code instruction of said microcontroller 
which when set forces data access to take place on 
a section of said random access memory storing 
special and general purpose registers while not 
affecting current operations of said microcontroller 
and not modifying said cunently selected address 
stored in an op-code instruction being executed by 
said microcontroller. 

2. A paging scheme for a microcontroller in accord- 
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ance with Claim 1 further comprising the steps of: 

linearizing an entire address range of said ran- 
dom access memory; and 
dedicating a first address section of said ran- 5 
dom access memory to special and general 
purpose registers. 
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data access to take place on a section of said 
random access memory storing special and 
general purpose registers while not affecting 
current operations of said microcontroller and 
not modifying said currently selected address 
stored in an op-code instruction being exe- 
cuted by said microcontroller. 



3. A paging scheme for a microcontroller in accord- 
ance with claim 2 wherein said step of linearizing io 
an entire address range of said random access 
memory further comprises the step of dividing said 
linearized address range of said random access 
memory into a plurality of pages. 

15 

4. A paging scheme for a microcontroller in accord- 
ance with Claim 3 wherein said step of dividing said 
linearized address range of said random access 
memory into a plurality of pages further comprises 
the step of dividing said linearized address range of 20 
said random access memory into a plurality of 
pages wherein each of said plurality of pages is 
256K in size. 



8. A paging scheme for a microcontroller in accord- 
ance with Claim 7 wherein said step of dividing said 
linearized address range of said random access 
memory into a plurality of pages further comprises 
the step of dividing said linearized address range of 
said random access memory into a plurality of 
pages wherein each of said plurality of pages is 
256K in size. 

9. A paging scheme for a microcontroller in accord- 
ance with Claim 7 wherein said step of dedicating a 
bit in each op-code instruction of said microcontrol- 
ler further comprises the step of dedicating a bit in 
only numeric processing op-code instructions of 
said microcontroller. 



5. A paging scheme for a microcontroller in accord- 25 
ance with Claim 2 wherein said step of dedicating a 

bit in each op-code instruction of said microcontrol- 
ler further comprises the step of dedicating a bit in 
only numeric processing op-code instructions of 
said microcontroller. 30 

6. A paging scheme for a microcontroller in accord- 
ance with Claim 5 wherein said step of dedicating a 
bit in only numeric processing op-code instructions 

of said microcontroller further comprises the step of 35 
removing non-numeric processing op code instruc- 
tions from an instruction decode map of said micro- 
controller to allow adding said dedicated bit in only 
said numeric processing op-code instructions of 
said microcontroller without increasing a size of 40 
said instruction decode map for said microcontrol- 
ler. 

7. A paging scheme for a microcontroller that uses 
data random access memory to allow tracking of a 45 
currently selected address in said random access 
memory comprising the steps of: 

linearizing an entire address range of said ran- 
dom access memory; 50 
dividing said linearized address range of said 
random access memory into a plurality of 
pages; 

dedicating a first page of said random access 
memory to special and general purpose regis- 55 
ters; and 

dedicating a bit in each op-code instruction of 
said microcontroller which when set forces 



10. A paging scheme for a microcontroller in accord- 
ance with Claim 9 wherein said stop of dedicating a 
bit in only numeric processing op-code instructions 
of said microcontroller further comprises the step of 
removing non-numeric processing op code instruc- 
tions from an instruction decode map to allow add- 
ing said dedicated bit in only said numeric 
processing op-code instructions of said microcon- 
troller without increasing a size of an instruction 
decode map of said microcontroller. 

11. A microcontroller having force page zero architec- 
ture comprising, in combination: 

random access memory having an entire line- 
arized address range wherein said random 
access memory is divided into a plurality of 
pages, said random access memory dedicating 
a first page to special and general purpose reg- 
isters; and 

a dedicated bit in each op-code instruction of 
said microcontroller which when set forces 
data access to take place on said first page of 
said random access memory storing said spe- 
cial and general purpose registers while not 
affecting current operations of said microcon- 
troller and not modifying said currently selected 
address stored in an op-code instruction being 
executed by said microcontroller. 

12. A microcontroller having force page zero architec- 
ture in accordance with Claim 1 1 wherein each of 
said plurality of pages of said random access mem- 
ory is 256K in size. 
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13. A microcontroller having force page zero architec- 
ture in accordance with Claim 1 1 wherein said ded- 
icated bit is placed only in numeric processing op- 
code instructions of said microcontroller 

5 
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(54) Force page zero paging scheme for microcontrollers 

(57) A microcontroller architecture that adds a dedi- 
cated bit in the op-code decode field to force data 
access to take place on page 0 of the random access 
memory (RAM) for that instruction. This allows the user 
to have any page selected and still have direct access to 
the special function registers or the register variables 
which are located on page 0 of the RAM. The setting of 
the dedicated bit will not affect the current operation of 
the microcontroller nor will the setting of the bit modify 
the currently selected address stored in the op-code 
instruction currently being executed by the microcontrol- 
ler. 
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